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The Claims 

1. (Currently amended) A method for determining where to store object 
replicas, the method comprising: 

receiving an indication of a homeless replica of an object, wherein the 
object has a plurality of replicas including the homeless replica; 

determining an initial placement for the homeless replica, wherein the 
initial placement is one of a plurality of devices in a system; 

evaluatin g, on an object bv object basis, whether any replicas of the object 
can be swapped with one of a plurality of replicas of another object and not reduce 
a combined object availability of the two objects; and 

swapping a replica of the object with the one of the plurality of replicas of 
the other object only if the swapping does not reduce the combined object 
availability of the two objects. 

2. (Original) A method as recited in claim 1, wherem the replica of the 
object is stored on a first computing device, wherein the one of the plurality of 
leplicas of the other object is stored on a second computing device, and wherein 
swapping the replicas comprises moving the replica of the object to the second 
computing device and moving the one of the plurality of replicas of the other 
object to the first computing device. 

3. (Original) A metiiod as recited in claim 1, wherein the method is 
implemented by multiple computing devices in a serverless distributed file system. 
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4. (Original) A method as recited in claim 1, wherein both the object and 
the other object have a same amoxmt of replicas, 

5. (Original) A method as recited in claim 1, wherein the object comprises 

a file. 

6. (Original) A method as recited in claim 1, wherein the object comprises 
aplurality of files. 

7- (Original) A method as recited in claim 1, wherein the object comprises 
a portion of a file. 

8. (Original) A method as recited in claim 1 , wherein the object comprises 
a directory. 

9. (Original) A method as recited in claim 1, wherein the detemiining 
comprises randomly selecting the initial placement for the homeless repHca. 

10. (Original) A method as recited in claim 1, wherein the evaluating 
comprises: 

detemiining, for each possible swapping of rephcas of the objects, an object 
availability for each object; and 
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checking whether any of the possible swappings result in a combined object 
availabiUty of the two objects that is greater than the combined object availabihty 
prior to the evaluating. 

11. (Original) A method as recited in claim 1, wherein combined object 
availability is not reduced if the availability of the object and the availability of the 
other object arc no further from one another than they were prior to the evaluating. 

12. (Original) A method as recited in claim 1, wherein the swapping 
results in increasing an availability of the object and decreasing an availabihty of 
the other object 

13. (Original) A method as recited in claim 1, wherein the swapping 
results in decreasing an availability of the object and increasing an availability of 
tibe other object. 

14. (Original) A method as recited in claim 1, implemented by a 
computing device and furrier comprising selecting, prior to the evaluating, as the 
object one of a plurality of objects that the computing device is responsible for 
maintaining. 

15. (Original) A method as recited in claim 14, wherein the selecting 
comprises randomly selecting one of the plurality of objects. 
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16. (Original) A method as recited in claim 14, wherein the selecting 
comprises selectiDg the one of the pliuality of objects that has the lowest object 
availability. 

17. (Original) A method as recited in claim 1 , wherein the other object is 
one of a plurality of objects that a computing device is responsible for 
maintaining, and wherein the other object is randomly selected from the plurality 
of objects. 

18. (Original) A method as recited in claim I , wherein the other object is 
one of a plurality of objects that a computing device is responsible for 
maintaining, and wherein the other object is the one of the plurality of objects that 
has the highest object availability. 

19. (Original) One or more computer readable media having stored 
thereon a plurality of instructions that, when executed by one or more processors 
of a computing device^ causes the one or more processors to perform acts 
comprising: 

working, in conjunction with one or more other processors of another 
computing device, to determine whether a replica of a file managed by the 
computing device and a replica of another file managed by the other computing 
device can be swapped with one another to bring an availability of the file and an 
availability of the other file closer; and 
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swapping the replica of the file at)d the rephca of the other file only if the 
swapping brings the availability of the file and the availability of the otfier file 
closer. 

20. (Original) One or more computer readable media as recited in claim 
19, wherein the swapping comprises communicating with a first device on which 
the replica of the file is stored and a second device on which the replica of the 
other file is stored to have the first device transfer the replica of the file to the 
second device and delete the replica of the file on the first device, and to have the 
second device transfer the replica of the other file to the first device and delete the 
replica of the other file on the second device, 

21- (Original) One or more computer readable media as recited tti claim 
19, wherein the one or more processors are part of a device in a serverless 
distributed file system. 

22. (Original) One or more computer readable media as recited in claim 
19, wherein the file represents a plurality of files. 

23. (Original) One or more computer readable media as recited in claim 
19, wherein the file represents a portion of another file. 

24. (Original) One or more computer readable media as recited in claim 
19, wherein the file represents a folder. 
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25. (Original) One or more computer readable media as recited in claim 
19, wherein the plurality of instructions further cause the one or more processors 
to perform acts comprising; 

receiving an indication of a homeless replica of the file; and 
determining an initial placement^ on one of a plurality of additional 
computing devices, for the homeless replica. 

26. (Original) One or more computer readable media as recited in claim 
25, wherein determining the initial placement comprises randomly selecting the 
initial placement for the homeless replica. 

27- (Original) One or more computer readable media as recited in claim 
25, wherein the plurality of additional computing devices exclude any coniputing 
device on which a replica of the file is already stored. 

28. (Original) One or more computer readable media as recited in claim 
19, wherein the file is selected randomly from a plurality of files managed by the 
computing device, and wherein the other file is selected randomly from another 
plurality of files managed by the other computing device. 

29. (Original) One or more computer readable media as recited in claim 
19, wherein the file is selected as the one of a plurality of files managed by the 
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computing device having a lowest file availability, and the other file is selected 
randomly from another plurality of files managed by the other computing device. 

30. (Original) One or more computer readable media as recited in claim 
19, wherein the file is selected as the one of a plurality of files managed by die 
computing device having a lowest file availability, and the other file is selected as 
ttie one of another plurality of files managed by the other computing device having 
a highest file availability. 

31. (Original) One or more computer readable media as recited in claim 
19, wherein the computing devices is part of a directory group that is collectively 
responsible for managing a plurality of files including the file, and wherein the 
other computing device is part of another directory group that is collectively 
responsible for managing another plurality of files including the other file* 

32. (Original) One or more computer readable media as recited in claim 
19, wherein the one or more processors of a computing device and the one or more 
other processors of another computing device are the same processors of the same 
computing device. 

33. (Original) A serverless distributed file system comprising: 
a first plurality of computing devices storing files; 

a $econd plurality of computing devices managing storage of the files; 
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wherein a first computing device of the second plurality of computing 
devices selects a fxle for which it manages storage and communicates with a 
second computing device of the second plurality of computing devices to 
determine whether a replica of the file and a replica of another file for which the 
second computing device manages storage can be swapped in order to improve a 
combined file availability; and 

if the replicas can be swapped to improve the combined file availability, 
then instructing the one of the first plurality of computing devices on which the 
replica of the file is stored to transfer the replica of the file to the one of the first 
plurality of computing devices on which the replica of the other file is stored, and 
instructing the one of the first plurality of computing devices on which ibs replica 
of the other file is stored to transfer the replica of the other file to the one of the 
first plurality of computing devices on which the replica of the file is stored. 

34. (Original) A serverless distributed file system as recited in claim 33, 
wherein the second plurality of computing devices comprise one or more directory 
groups. 

35. (Original) A serverless distributed file system as recited in claim 33, 
wherein the second plurality of computing devices further receives an indication 
of a homeless replica of the file, and randomly selects, as a computing device on 
which to store the homeless replica, one of the first plurality of computing devices 
on which no other replica of the file is already stored. 
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36- (Qirrently amended) One or more computer readable media having 
stored thereon a plurality of instructions that, when executed by one or more 
processors of a computing device, causes the one or more processors to: 

initially place replicas of a file on different ones of a plurality of devices 
using a first process; and 

subsequently improve the placement of replicas of a plurality of files by 
evaluatin g, on a file bv file basis, whether any replicas of a first file can be 
swapped with any replicas of a second file without a reduction in fhe combined 
file availability of the first and second files, and swapping a replica of the first file 
with a replica of the second file if the swapping results in no reduction in the 
combined file availability of the first and second files. 

37. (Original) One or more computer readable media as recited in claim 
36, wherein the first process comprises random selection. 

38. (Original) One or more computer readable media as recited in claim 
36, wherein swapping the replica of the first file with the replica of the second file 
comprises communicating with a first device on which the replica of the fir$t file 
is stored and a second device on which the replica of the second file is stored to 
have fhe first device transfer the replica of the first file to the second device and 
delete the replica of the first file on the first device^ and to have the second device 
transfer the replica of the second file to the first device and delete the replica of the 
second file on the second device. 
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39. (Original) One or more computer readable media as recited in claim 
36. wherein the first file is selected randomly from a first plurality of files, and 
wherein the second file is selected randomly from a second plurality of files. 

40. (Original) One or more computer readable media as recited in claim 
36, wherein the first file is selected as the one of a first plurality of files having a 
lowest file availability, and the second file is selected randomly from a second 
plurality of files. 

41. (Original) One or more con^juter readable media as rcated in claim 
36, wherein the first file is selected as the one of a furst plurality of files managed 
having a lowest file availability, and the second file is selected as the one of a 
second plurality of files having a highest file availabiliQr. 

42. (Original) A method, implemented in a directory group, the method 

comprising: 

selecting another directory group to participate with in a replica placement 
improvement process; 

selecting a file ooaintained by the directory group; 

determining whether exchanging a replica of the file with a replica of 
another file maintained by the other directory group will increase a combined file 
availability of the files; and 

having the replica of the file and the replica of the other file exchanged if 
exchanging the replicas will increase the combined file availability of the files. 



j^j^^ 11 ApplkaBon NO. 10(092,994 

PA(X1S39'RCVDAT1(ll2M2:13:3SPMps(em Daylight TiinepsVR:USPTO€^^ 



OCT 25 2005 li:i9 FR 00 



15093238979 TO 15712738300 P. 16/39 



43. (Original) A method as recited in claim 42, further comprisiiig: 
receiving, at the directory group» an indication of a homeless replica of the 

file; and 

selecting, as a computing device on which to store the homeless replica, 
one of a plurality of computing devices on which no other replica of the file is 
already stored. 

44. (Original) A method as recited in claim 42, wherein the selecting 
comprises randomly selecting. 

45. (Original) A method as recited in claim 42, wherein having tiie replica 
of the file and the replica of the other iile exchanged comprises communicating 
mih a first device on which the replica of the file is stored and a second device on 
which the replica of the other file is stored to have the first device transfer the 
replica of the file to the second device and delete the replica of the file on the first 
device, and to have the second device transfer the replica of the other file to the 
first device and delete the replica of the other file on the second device. 

46. (Original) A method as recited in claim 42, wherein the file is selected 
randondy fcom a plurality of files managed by the directory group, and wherein 
the other file is selected randomly fix>m another plurality of files managed by the 
other directory group. 
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47. (Original) A method as recited in claim 42, wherein the file is selected 
as the one of a plurality of files managed by the directory group having a lowest 
file availability, and the other file is selected randomly fi:om anotiicr plurality of 
files managed by the other directory group. 

48, (Original) A method as recited in claim 42, wherein the file is selected 
as the one of a plurality of files managed by the directory group having a lowest 
file availability, and the other file is selected as the one of another plurality of files 
managed by the other directory group having a highest file availability. 
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